package com.pochogastos.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import javax.naming.NamingException;

import com.pochogastos.db.DBManager;
import com.pochogastos.model.Categoria;

public class CategoriaDAO {
	
	private static CategoriaDAO instancia;
	
	public static CategoriaDAO getInstance(){
		if(instancia == null)
			instancia = new CategoriaDAO();
		return instancia;
	}
	
	public int insertCategoria(String nombre,String idUsuario)throws SQLException, ClassNotFoundException, NamingException{
			Connection conn = DBManager.getInstance().getConnection();
			PreparedStatement pstmt = conn.prepareStatement("INSERT INTO gastos.categoria(nombre,id_usuario) VALUES (?,?)", Statement.RETURN_GENERATED_KEYS);
			pstmt.setString(1, nombre);
			pstmt.setInt(2, Integer.parseInt(idUsuario));
			pstmt.executeUpdate();
			ResultSet rs = pstmt.getGeneratedKeys();
			rs.next();
			return rs.getInt(1);
	}
	
	public List<Categoria> getCategorias(String idUsuario) throws SQLException, ClassNotFoundException, NamingException{
		List<Categoria> listaCategorias = new ArrayList<Categoria>();
			Connection conn = DBManager.getInstance().getConnection();
			PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM gastos.categoria WHERE id_usuario = ?");
			pstmt.setInt(1, Integer.parseInt(idUsuario));
			ResultSet rs = pstmt.executeQuery();
			while(rs.next()){
				Categoria c = new Categoria();
				c.setId(rs.getInt(1));
				c.setNombre(rs.getString(2));
				listaCategorias.add(c);
			}
		return listaCategorias;
	}

}
